<?php

class Ead_RedacaoController extends Ead_Controller_Action
{

    private $_table     = 'ENVIO_ARQUIVO';
    private $_pk        = 'EVA_ID';
    private $_order_col = 'EVA_DATHOR';
    private $_order     = 'DESC';
    private $_sta_col   = 'EVA_STA';
    private $obj        = '';
    private $form       = '';
    
    public  $dir        = 'public/upload/enviodearquivo/';
    public  $dir2       = 'public/upload/enviodearquivocorrecao/';
    public  $_file_col  = 'arquivo';
    
    public function init()
    {
    
    }

    public function indexAction() {
        
        Zend_Loader::loadClass('datetools','library');
        Zend_Loader::loadClass('imagem','library');
        Zend_Loader::loadClass('dominio','library');
        
        $sessao = new Zend_Session_Namespace('Aluno');
        
        $where = $this->_pk . ' > 0 AND ALU_ID = '.$sessao->aluno['ALU_ID'];
        
        $query = 'SELECT SQL_CACHE * FROM '.$this->_table.' WHERE '.$where.' ORDER BY '.$this->_order_col.' '.$this->_order;
        $result = $this->db->fetchAll($query);
        $this->view->result = $this->paginacao($result);
        
        
        $query = 'SELECT SQL_CACHE c.CUR_ID, c.CUR_REDENV, c.CUR_REDCOR, m.MAT_ID '
            .' FROM MATRICULA m, CURSO c '
            .' WHERE m.ALU_ID = '.$sessao->aluno['ALU_ID'].' '
            .' AND m.CUR_ID = c.CUR_ID '
            .' AND m.MAT_STA = 1';
        $cur = $this->db->fetchRow($query);
        $this->view->cur = $cur;
        
        $query = 'SELECT SQL_CACHE count(*) as TOTAL '
                .' FROM ENVIO_ARQUIVO '
                .' WHERE ALU_ID = '.$sessao->aluno['ALU_ID']
                .' AND MAT_ID = '.$cur['MAT_ID']
                .' AND CUR_ID = '.$cur['CUR_ID'];
        $cor = $this->db->fetchRow($query);
        $this->view->cor = $cor;
        
        // envio de redação
        if($this->getRequest()->isPost()) { 
        
            if(strlen($_FILES[$this->_file_col]['name']) > 5 && $cur['CUR_REDENV'] > $cor['TOTAL'] && $cur['CUR_REDENV'] > 0){

                Zend_Loader::loadClass('imagem','library');

                $sessao = new Zend_Session_Namespace('Aluno');

                $letra = dominio::getLetra(0);

                $data = array(
                    'EVA_NOM'   => $_FILES[$this->_file_col]['name'],
                    'ALU_ID'    => $sessao->aluno['ALU_ID'],
                    'EVA_DATHOR'=> date('Y-m-d H:i:s'),
                    'MAT_ID'    => $cur['MAT_ID'],
                    'CUR_ID'    => $cur['CUR_ID'],
                );
                $this->db->insert('ENVIO_ARQUIVO',$data);
                $id = $this->db->lastInsertId();
                
                $data = array('EVA_NOM' => $id.$letra);
                $this->db->update('ENVIO_ARQUIVO',$data,'EVA_ID = '.$id);

                $returnImg = imagem::upload($this->_file_col,$this->dir,$id);
                imagem::rename($id.$letra,$this->dir,$returnImg['filenew']);

                //echo '<script>alert("Enviado arquivo com sucesso!")</script>';
                $this->_helper->redirector('index');
            }
            else{
                if(strlen($_FILES[$this->_file_col]['name']) > 5 && $cur['CUR_REDENV'] >= $cor['TOTAL'] && $cur['CUR_REDENV'] > 0){
                    echo '<script>alert("Você já utilizou o limite de envio de redações!")</script>';
                }
            }
        
        }
        
    }
    
    public function correcaoAction() {
        
        Zend_Loader::loadClass('datetools','library');
        Zend_Loader::loadClass('imagem','library');
        Zend_Loader::loadClass('dominio','library');
        
        $sessao = new Zend_Session_Namespace('Aluno');
        
        $eva_id = $this->_getParam('id', 0);
        $this->view->eva_id = $eva_id;
        $where = 'c.EVA_ID = '.$eva_id;
       
        $where .= ' AND e.ALU_ID = '.$sessao->aluno['ALU_ID'];
        
        $query = 'SELECT SQL_CACHE c.* '
                .' FROM ENVIO_ARQUIVO e, ENVIO_ARQUIVO_CORRECAO c '
                .' WHERE '.$where
                .' AND c.EVA_ID = e.EVA_ID '
                .' ORDER BY c.EVC_DATHOR DESC';
        $result = $this->db->fetchAll($query);
        $this->view->result = $this->paginacao($result);
        
        
        $query = 'SELECT SQL_CACHE c.CUR_ID, c.CUR_REDENV, c.CUR_REDCOR, m.MAT_ID '
            .' FROM MATRICULA m, CURSO c '
            .' WHERE m.ALU_ID = '.$sessao->aluno['ALU_ID'].' '
            .' AND m.CUR_ID = c.CUR_ID '
            .' AND m.MAT_STA = 1';
        $cur = $this->db->fetchRow($query);
        $this->view->cur = $cur;
        
        $query = 'SELECT SQL_CACHE count(*) as TOTAL '
                .' FROM ENVIO_ARQUIVO_CORRECAO '
                .' WHERE EVA_ID = '.$eva_id
                .' AND EVC_TPO = 0'
                .' AND ALU_ID = '.$sessao->aluno['ALU_ID']
                .' AND MAT_ID = '.$cur['MAT_ID']
                .' AND CUR_ID = '.$cur['CUR_ID'];
        $cor = $this->db->fetchRow($query);
        $this->view->cor = $cor;
        
        // envio de redação
        if($this->getRequest()->isPost()) { 
        
            // envio de redação
            if(strlen($_FILES[$this->_file_col]['name']) > 5 && $cur['CUR_REDCOR'] > $cor['TOTAL'] && $cur['CUR_REDCOR'] > 0){

                Zend_Loader::loadClass('imagem','library');

                $where = 'EVA_ID = '.$eva_id;
                $query = 'SELECT count(*) as TOTAL FROM ENVIO_ARQUIVO_CORRECAO WHERE '.$where;
                $row = $this->db->fetchRow($query);
                $letra = dominio::getLetra($row['TOTAL'] + 1);

                $data = array(
                    'EVC_NOM' => $_FILES[$this->_file_col]['name'],
                    'EVC_DATHOR' => date('Y-m-d H:i:s'),
                    'EVA_ID' => $eva_id,
                    'USU_ID' => Zend_Auth::getInstance()->getStorage()->read()->USU_ID,
                    'EVC_LTR' => $letra,
                    'EVC_TPO' => 0,
                    'EVC_STA' => 1,
                    'ALU_ID'    => $sessao->aluno['ALU_ID'],
                    'MAT_ID'    => $cur['MAT_ID'],
                    'CUR_ID'    => $cur['CUR_ID'],
                );
                $this->db->insert('ENVIO_ARQUIVO_CORRECAO',$data);
                $id = $eva_id;

                $returnImg = imagem::upload($this->_file_col,$this->dir2 ,$id);
                imagem::rename($id.$letra,$this->dir2 ,$returnImg['filenew']);

                echo '<script>alert("Enviado arquivo com sucesso!");location.reload();</script>';

            }
            else{
                if(strlen($_FILES[$this->_file_col]['name']) > 5 && $cur['CUR_REDCOR'] >= $cor['TOTAL'] && $cur['CUR_REDCOR'] > 0){
                    echo '<script>alert("Você já utilizou o limite de envio de redações!")</script>';
                }
            }
        }
        
    }
}